<?php
/**
 * @title 841. 钥匙和房间 - 哈希+迭代
 * @author start2004
 */

// ini_set("memory_limit", "128M");


class Solution {

    /**
     * @param Integer[][] $rooms
     * @return Boolean
     */
    function canVisitAllRooms($rooms) {
        /**
         * @since 2020-08-31 哈希
         */
        $hashs = [0=>1];

        /**
         * @since 2020-08-31 迭代
         */
        $nexts = [0];
        while($nexts){
            $nextsTmp = [];

            /**
             * @since 2020-08-31 依次检查每个房间
             */
            foreach ($nexts as $rootNum){
                foreach ($rooms[$rootNum] as $nextNum){
                    if(!isset($hashs[$nextNum])){
                        $hashs[$nextNum] = 1;
                        $nextsTmp[] = $nextNum;
                    } else {}
                }
            }

            /**
             * @since 2020-08-31 下次迭代
             */
            $nexts = $nextsTmp;
        }

        /**
         * @since 2020-08-31 是否打开所有房间
         * @return
         */
        return count($hashs) === count($rooms);
    }
}


/**
 * @url http://127.0.0.1/leetcode/202008/2020.08.31.php
 */
$datas = [
    [[1],[2],[3],[]],
    [[1,3],[3,0,1],[2],[0]],
];

include_once dirname(__DIR__) . DIRECTORY_SEPARATOR ."xhprof.php";
$xhprof = new Xhprof();
foreach ($datas as $data){
    var_dump($data);

    $obj = new Solution();
    $result = $obj->canVisitAllRooms($data);
    var_dump($result);
    // if(count($result)<=20){
    //     var_dump($result);
    // } else {
    //     var_dump(count($result));
    // }
    echo str_repeat("<br>", 3);
}

// foreach ($datas as $data){
//     $obj = new $data[0][0](...$data[1][0]);
//
//     for ($i=1; $i<count($data[0]); $i++){
//         $result = $obj->$data[0][$i](...$data[1][$i]);
//
//         echo $data[0][$i] ."(\"". $data[1][$i][0] ."\") ";
//             if($result === true){
//                 echo "True";
//             } elseif($result === false) {
//                 echo "False";
//             } elseif($result === null) {
//                 echo "Null";
//             } elseif(is_array($result)) {
//                 var_dump($result);
//             } else {
//                 echo $result;
//             }
//         echo PHP_EOL;
//     }
//
//     echo str_repeat(PHP_EOL, 3);
// }
$xhprof->end();
